<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
</head>
<body>
  <div id="box"><input type="checkbox" name="" id=""> 全选</div>
  <ul>
    <li><input type="checkbox" name="" id="">汽车</li>
    <li><input type="checkbox" name="" id="">房子</li>
    <li><input type="checkbox" name="" id="">车位</li>
    <li><input type="checkbox" name="" id="">存款</li>
  </ul>

  <script>
    // var allCheck = document.querySelector('#box').querySelector('input')
    var allCheck = document.querySelector('#box input')
    var listChecks = document.querySelectorAll('ul input')

    allCheck.onclick = function() {  // 全选点击事件
      console.dir(this.checked)

      for(var i = 0; i < listChecks.length; i++) {
        listChecks[i].checked  = this.checked
      }
    }

    // 1. 给 list的 checkbox都注册⌚️
    for(var i = 0; i < listChecks.length; i++) {
      listChecks[i].onclick = function() {
        // 2. // 假设 全选要选中
        var flag = true  // 假设 全选要选中

        for(var j = 0; j < listChecks.length; j++) {  // 3. 判断所有list的checkbox是否选中，如果有没选中的，则说明假设失败
          if(listChecks[j].checked === false) {
            flag = false
            break
          }
        }

        // 4. 将到底是不是要选中的 标示 flag 赋值给 全选checkbox
        allCheck.checked = flag
      }
    }
  </script>
</body>
</html>